草庐IT

Python之faker 生成测试数据

全部标签

sql - Rails 中独立于数据库的 SQL 字符串连接

我想在Rails查询中进行数据库端字符串连接,并以独立于数据库的方式进行。SQL-92指定双杠(||)作为连接运算符。不幸的是,MSSQLServer似乎不支持它;它使用+代替。我猜Rails的SQL语法抽象已经解决了特定于数据库的运算符问题。如果它确实存在,我该如何使用它? 最佳答案 我遇到了同样的问题,但从未想出任何内置于Rails中的东西。所以我写了这个小方法。#Symbolsshouldbeusedforfieldnames,everythingelsewillbequotedasastringdefdb_concat(*a

ruby - Python itertools 的 Ruby 等价物是什么,尤其是。组合/排列/groupby?

Python的itertools模块提供了很多关于使用生成器处理可迭代/迭代器的好东西。例如,permutations(range(3))-->012021102120201210combinations('ABCD',2)-->ABACADBCBDCD[list(g)fork,gingroupby('AAAABBBCCD')]-->AAAABBBCCDRuby中有哪些等价物?等效的,我的意思是快速和内存高效(Python的itertools模块是用C编写的)。 最佳答案 Array#permutation、Array#combin

ruby - 如何运行独立的 Capybara 测试?

我正在尝试针对远程服务器运行测试。即:require'rubygems'require'capybara'require'capybara/dsl'Capybara.default_driver=:seleniumCapybara.app_host='http://www.google.com'moduleMyCapybaraTestincludeCapybaradeftest_googlevisit('/')endend问题是,你如何运行它? 最佳答案 保存require'rubygems'require'capybara'req

sql - 将每个 SQL 查询记录到 Rails 中的数据库

我想将某些SQL查询rails执行(即CREATE、UPDATE和DELETE)保存到日志文件中因此我需要拦截所有查询,然后可能使用一些正则表达式过滤它们并根据需要记录它们。我应该把这样的东西放在Rails代码的什么地方? 最佳答案 这里是c0r0ner链接的简化版本,以更好地展示它:connection=ActiveRecord::Base.connectionclasse;end#executeoriginalstatementoriginal_exec(sql,*name)endend

ruby-on-rails - 基于当前的托管服务,我应该将哪些数据库与 Ruby on Rails 一起使用?

我一直在寻找托管服务,但我仍然不知道哪种数据库最常见。好像是MySql和PostgreSql。所以,我不确定我的网站会有多少流量和数据(这只是一个项目),但我想做好准备。我曾在Oracle(PL/SQL)的一些项目中工作过,我对MySql有所了解。谢谢!附言。4年后,我主要使用PostgreSQL编写RoR。当我需要简单的应用程序时默认使用SQLite,否则使用PostgreSQL。 最佳答案 Rails的一个原则是你不应该真正关心你使用的是什么数据库:这些都是为你抽象的。所以我会说选择总体上最好的托管服务提供商,并相信他们会选择一

ruby-on-rails - ActionDispatch::Http::UploadedFile.content_type 未在 Rspec 测试中初始化

背景:我有一个带有cover_file属性的Book模型,该模型通过我的一个RailsController使用上传的文件进行设置。我正在使用Railsv4.0.4。目标:我想测试只保存具有特定内容类型的文件。我计划使用设置了不同content_type属性的ActionDispatch::Http:UploadedFile对象创建Rspec测试示例。问题:当我用content_type初始化一个新的ActionDispatch::Http::UploadedFile时,它似乎没有被设置(请参阅下面的测试和输出,确认它为零)。看来我只能在UploadedFile初始化后用setter设置

ruby-on-rails - 如何使用 ActiveRecord 最好地处理每个模型的数据库连接?

我想要规范的方式来做到这一点。我的Google搜索没有结果。我有一个ActiveRecord模型,它应该映射到与应用程序其余部分不同的数据库。我也想将新配置存储在database.yml文件中。我知道应该调用establish_connection,但不清楚在哪里。这是我到目前为止所得到的,但它不起作用:classFoo 最佳答案 此外,将使用不同数据库的模型子类化是个好主意,例如:classAnotherBase在你的模型中classFoo当您需要添加访问同一个数据库的后续模型时,它很有用。

ruby-on-rails - 如何在 Capybara 和 RSpec 中测试 CSV 文件下载?

Controller中的内容如下:respond_todo|format|format.csv{send_dataas_csv,type:'text/csv'}end在规范中:click_link'DownloadCSV'page.driver.browser.switch_to.alert.acceptexpect(page).tohave_contentcsv_data但这行不通:Failure/Error:page.driver.browser.switch_to.alert.acceptSelenium::WebDriver::Error::NoAlertPresentErro

ruby-on-rails - 如何检查 HTTParty 生成的完整 URL?

我想查看HTTPartygem根据我的参数构建的完整URL,无论是在提交之前还是提交之后,都没有关系。我也很乐意从响应对象中获取它,但我也看不到这样做的方法。(背景知识)我正在使用HTTPartygem为API构建包装器。它可以正常工作,但偶尔我会收到来自远程站点的意外响应,我想深入了解原因–是不是我发送的内容不正确?如果是这样,什么?我是否以某种方式使请求格式错误?查看原始URL有助于进行故障排除,但我看不出如何。例如:HTTParty.get('http://example.com/resource',query:{foo:'bar'})大概会产生:http://example.c

ruby-on-rails - Ruby on Rails - 为什么要使用测试?

我对RubyonRails中的各种测试设备的用途感到困惑。我已经使用该框架大约6个月了,但我从未理解它的测试部分。我使用过的唯一测试是Java中的JUnit3,而且只是简短的。我读过的关于它的一切都只是显示了测试验证。rails中的验证不应该起作用吗?看起来更像是测试框架而不是测试您的代码。为什么需要测试验证?此外,测试对于代码中的任何更改似乎都非常脆弱。因此,如果您更改模型中的任何内容,则必须更改测试和装置以匹配。这不是违反了DRY原则吗?第三,编写测试代码似乎需要很多时间。这是正常的吗?刷新我的浏览器并查看它是否有效不是更快吗?我已经不得不使用我的应用程序来查看它是否正确流动并确保